iT邦幫忙

2019 iT 邦幫忙鐵人賽

DAY 3
9

本文已搬家到筆者自己的部落格嘍,有興趣的可以點這個連結

什麼是DOM

DOM 全名為 Document Object Model 中文翻譯為 文件物件模型,看起來很抽象但其實就是把一份 HTML 文件內的各個標籤,包括文字、圖片等等都定義成物件,而這些物件最終會形成一個樹狀結構,下面有一張示意圖可以參考。

為何需要DOM

網頁是由瀏覽器負責運行,因此可以知道瀏覽器其實就是一種編譯器負責去編譯我們寫的網頁程式,有非常多間公司都在設計瀏覽器,假如沒有先定好一個規則讓各個瀏覽器都必須要按照這個規則去編譯我們的網頁程式的話,工程師豆頁就痛了,處理一個IE已經夠煩了還要去針對各個瀏覽器去寫出他們的規則,也因此 W3C 出現了, W3C 定義了非常多的網頁規則好讓各大瀏覽器可以按照這些規則去設計瀏覽器,其中 DOM 就是其中的一個定義。

DOM解析

既然上面都提到 DOM 會形成一個樹狀結構,而樹狀結構最重要的就是各個 節點(node)

DOM 中,每個 element文字(text) 等等都是一個節點,而節點通常分成以下四種:

  • Document

    Document 就是指這份文件,也就是這份 HTML 檔的開端,所有的一切都會從 Document 開始往下進行。
  • Element

    Element 就是指文件內的各個標籤,因此像是 <div><p> 等等各種 HTML Tag 都是被歸類在 Element 裡面。
  • Text

    Text 就是指被各個標籤包起來的文字,舉例來說在 <h1>Hello World</h1> 中, Hello World<h1> 這個 Element 包起來,因此 Hello World 就是此 ElementText
  • Attribute

    Attribute 就是指各個標籤內的相關屬性,這裡在昨天的 HTML 基本觀念 有詳細闡述過了,如果有不懂的讀者可以查看 Day02 的文章。

範例

這邊以一個簡單的code來總結一下上述所說的事項,並把這份文件(document)內的元素(element)變成一個樹狀結構。

<html>
  <head>
    <title>example</title>
  </head>
  <body>
    <h1 class="txt">Hello World</h1>
  </body>
</html>

首先是最一開始的 document ,往下開始遇到 <html> 這個 element ,這個 <html> 包含了 <head> 以及 <body> 這兩個 element ,其中 <head> 這個 element 包含了 <title> 這個 element<title>textexample,再來是 <body> 這個 element 包含了 <h1> 這個 element<h1>textHello World attributeclass

看起來很像在繞口令,但瀏覽器就是這樣一步一步的把 HTML 解析(parse) 成一顆 DOM tree ,最後我們把上述的這些內容變成樹狀結構就會長成下圖這樣。

DOM 遍歷

由於 DOM 為樹狀結構,樹狀結構最重要的觀念就是 Node 彼此之間的關係,這邊可以分成以下兩種關係:

  • 父子關係(Parent and Child)

    簡單來說就是上下層節點,上層為 Parent Node ,下層為 Child Node

  • 兄弟關係(Siblings)

    簡單來說就是同一層節點,彼此間只有 Previous 以及 Next 兩種。

DOM 操作

講了那麼多觀念接下來就是要實際操作了,這邊會介紹一些常用的 DOM API ,首先先從抓取 Nodes 開始。

  • document.getElementById('idName')

    找尋 DOM 中符合此 id 名稱的元素,並回傳相對應的 element

  • document.getElementsBytagName('tag')

    找尋 DOM 中符合此 tag 名稱的所有元素,並回傳相對應的 element 集合,集合為 HTMLCollection

  • document.getElementsByClassName('className')

    找尋 DOM 中符合此 class 名稱的所有元素,並回傳相對應的 element 集合,集合為 HTMLCollection

  • document.querySelector('selector')

    利用 selector 來找尋 DOM 中的元素,並回傳相對應的第一個 element

  • document.querySelectorAll('selector')

    利用 selector 來找尋 DOM 中的所有元素,並回傳相對應的第一個 element ,集合為 NodeList

這裡稍微提一下 HTMLCollection 以及 NodeList ,兩個都是 Collection of DOM Nodes ,那到底差在哪呢?

  • HTMLCollection

    集合內元素為 HTML element ,也因此 Node type 只能接受 Element

  • NodeList

    集合內元素為 Node ,也因此全部的 Node 都可以存放在 NodeLists 內。

其實真正常用的 DOM API 也就這幾種而已,尤其 jQuery 盛行,讓 HTMLJavaScript 的溝通更加精簡容易,也因此越來越多人捨棄 DOM API 進而投向 jQuery 的懷抱,筆者在未來的文章也會加以闡述這個 JavaScript Library

總結小練習

最後讓我們用一個簡單的練習來總結上述的內容, DOM 最重要的就是觀念,為了不讓網頁在渲染的過程中過度的 重畫頁面(Repaint) 甚至是 重構頁面(Reflow) 而讓網頁效能變差,在 DOM 的操作上可要非常小心,而 DOM 可以說是網頁的核心,將 DOM 寫好網頁自然就會美好了!


上一篇
Day02-網頁三兄弟:HTML、CSS、JavaScript
下一篇
Day04-CSS選擇器
系列文
從0開始的網頁生活!30天從網頁新手到網頁入門30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中
0
willytcf
iT邦新手 5 級 ‧ 2019-05-06 04:47:39

解釋得很詳盡,幫了我這個門外漢不少,多謝作者,希望你能繼續努力,寫更多其他不同程式語言的文章。

0
anniecat
iT邦新手 3 級 ‧ 2019-07-18 16:31:05

請問這張圖片上的node指的是Document、Element,然後leaf的部份指的是Text或Attribute嗎?
https://ithelp.ithome.com.tw/upload/images/20190718/201153363iJRBNV4ru.jpg

0
jojo0927
iT邦新手 5 級 ‧ 2023-03-02 08:48:42

感謝分享

我要留言

立即登入留言